--    Author    : MAYANTING
--    Name      : ADM.RPT_SUST_DLMG_PAST_SCALE_ORG_LOAB.HQL
--    Functions : 表34：贷款余额分机构类型分企业规模统计表
--    Purpose   :
--    Revisions or Comments
--    VER        DATE        AUTHOR           DESCRIPTION
--   ---------  ----------  ---------------  ------------------------------------
--    1.0        2018-06-11  MAYANTING           1.CREATE THE PROCEDURE
--
INSERT OVERWRITE TABLE ADM.RPT_SUST_DLMG_PAST_SCALE_ORG_LOAB PARTITION (DATA_DATE = '20180331')
    SELECT
     AREA.AREA_CODE_4                                                             AS FIN_ORG_DIST
    ,YE.CCY                                                                       AS CCY
    ,ORG.ORG_CODE                                                                 AS ORG_TYP            -- 机构类型
    ,ORG.ORG_DSCR                                                                 AS ORG_DESC           -- 机构类型描述
    ,YE.ENTERPRISE_SCALE                                                          AS ENTERPRISE_SCALE   -- 企业规模
    ,CASE WHEN YE.ENTERPRISE_SCALE='CS01' THEN '大型企业'
          WHEN YE.ENTERPRISE_SCALE='CS02' THEN '中型企业'
          WHEN YE.ENTERPRISE_SCALE='CS03' THEN '小型企业'
          WHEN YE.ENTERPRISE_SCALE='CS04' THEN '微型企业'
     END                                                                          AS SCALE_DESC       -- 企业规模描述
    ,SUM(COALESCE(YE.ACTUAL_BAL,0))/100000000                                     AS ACTUAL_BAL       -- 贷款余额
    ,SUM(COALESCE(YE.BAL_LM,0))/100000000                                         AS BAL_LM           -- 余额上期末
    ,SUM(COALESCE(YE.BAL_YF,0))/100000000                                         AS BAL_YF           -- 余额年初 0101
    ,SUM(COALESCE(YE.ACTUAL_BAL,0) - COALESCE(YE.BAL_LC,0))/100000000             AS BAL_GROW         -- 同比增长
    ,SUM(COALESCE(YE.WSUM_BAL,0)/100000000                                        AS WSUM_BAL         -- 余额加权值
    ,SUM(COALESCE(YE.WBAL_LM,0))/100000000                                        AS WBAL_LM          -- 余额加权值上期末
    ,SUM(COALESCE(YE.WBAL_YF,0))/100000000                                        AS WBAL_YF          -- 余额加权值年初
    ,SUM(COALESCE(YE.WBAL_LC,0))/100000000                                        AS WBAL_LC          -- 余额加权值去年同期
    FROM (SELECT * FROM EDW.DS_LOAB_SUM WHERE ENTERPRISE_SCALE IN('CS01','CS02','CS03','CS04') AND DATA_DATE='20180331') YE
    -- 与地区表最细级关联
    LEFT JOIN (SELECT * FROM DIMENSION.T_ORG_AREA_RELATION WHERE AREA_LEVEL='3') REAL ON YE.FIN_ORG_NO=REAL.ORG_ID AND '20180331' BETWEEN REAL.START_DATE AND REAL.END_DATE
    LEFT JOIN DIMENSION.T_AREA_CODE AREA ON REAL.AREA_CODE=AREA.AREA_CODE_4 AND '20180331' BETWEEN AREA.START_DATE AND AREA.END_DATE
    -- 关联机构表
    LEFT JOIN DIMENSION.T_ORG_REPORT ORG ON YE.ORG_TYPE=ORG.ORG_CODE
    GROUP BY  AREA.AREA_CODE_4
             ,YE.CCY
             ,ORG.ORG_CODE
             ,ORG.ORG_DSCR
             ,YE.ENTERPRISE_SCALE
             ,CASE WHEN YE.ENTERPRISE_SCALE='CS01' THEN '大型企业'
                   WHEN YE.ENTERPRISE_SCALE='CS02' THEN '中型企业'
                   WHEN YE.ENTERPRISE_SCALE='CS03' THEN '小型企业'
                   WHEN YE.ENTERPRISE_SCALE='CS04' THEN '微型企业'
              END

    UNION ALL

    -- 中小企业
    SELECT
     AREA.AREA_CODE_4                                                             AS FIN_ORG_DIST
    ,YE.CCY                                                                       AS CCY
    ,ORG.ORG_CODE                                                                 AS ORG_TYP            -- 机构类型
    ,ORG.ORG_DSCR                                                                 AS ORG_DESC           -- 机构类型描述
    ,'CS234'                                                                      AS ENTERPRISE_SCALE   -- 企业规模
    ,'中小企业'                                                                   AS SCALE_DESC         -- 企业规模描述
    ,SUM(COALESCE(YE.ACTUAL_BAL,0))/100000000                                     AS ACTUAL_BAL         -- 贷款余额
    ,SUM(COALESCE(YE.BAL_LM,0))/100000000                                         AS BAL_LM             -- 余额上期末
    ,SUM(COALESCE(YE.BAL_YF,0))/100000000                                         AS BAL_YF             -- 余额年初 0101
    ,SUM(COALESCE(YE.ACTUAL_BAL,0) - COALESCE(YE.BAL_LC,0))/100000000             AS BAL_GROW           -- 同比增长
    ,SUM(COALESCE(YE.WSUM_BAL,0)/100000000                                        AS WSUM_BAL           -- 余额加权值
    ,SUM(COALESCE(YE.WBAL_LM,0))/100000000                                        AS WBAL_LM            -- 余额加权值上期末
    ,SUM(COALESCE(YE.WBAL_YF,0))/100000000                                        AS WBAL_YF            -- 余额加权值年初
    ,SUM(COALESCE(YE.WBAL_LC,0))/100000000                                        AS WBAL_LC            -- 余额加权值去年同期
    FROM (SELECT * FROM EDW.DS_LOAB_SUM WHERE ENTERPRISE_SCALE IN('CS02','CS03','CS04') AND DATA_DATE='20180331') YE
    -- 与地区表最细级关联
    LEFT JOIN (SELECT * FROM DIMENSION.T_ORG_AREA_RELATION WHERE AREA_LEVEL='3') REAL ON YE.FIN_ORG_NO=REAL.ORG_ID AND '20180331' BETWEEN REAL.START_DATE AND REAL.END_DATE
    LEFT JOIN DIMENSION.T_AREA_CODE AREA ON REAL.AREA_CODE=AREA.AREA_CODE_4 AND '20180331' BETWEEN AREA.START_DATE AND AREA.END_DATE
    -- 关联机构表
    LEFT JOIN DIMENSION.T_ORG_REPORT ORG ON YE.ORG_TYPE=ORG.ORG_CODE
    GROUP BY  AREA.AREA_CODE_4
             ,YE.CCY
             ,ORG.ORG_CODE
             ,ORG.ORG_DSCR

    UNION ALL

    -- 小微企业
    SELECT
     AREA.AREA_CODE_4                                                             AS FIN_ORG_DIST
    ,YE.CCY                                                                       AS CCY
    ,ORG.ORG_CODE                                                                 AS ORG_TYP           -- 机构类型
    ,ORG.ORG_DSCR                                                                 AS ORG_DESC          -- 机构类型描述
    ,'CS34'                                                                       AS ENTERPRISE_SCALE  -- 企业规模
    ,'小微企业'                                                                   AS SCALE_DESC        -- 企业规模描述
    ,SUM(COALESCE(YE.ACTUAL_BAL,0))/100000000                                     AS ACTUAL_BAL       -- 贷款余额
    ,SUM(COALESCE(YE.BAL_LM,0))/100000000                                         AS BAL_LM           -- 余额上期末
    ,SUM(COALESCE(YE.BAL_YF,0))/100000000                                         AS BAL_YF           -- 余额年初 0101
    ,SUM(COALESCE(YE.ACTUAL_BAL,0) - COALESCE(YE.BAL_LC,0))/100000000             AS BAL_GROW         -- 同比增长
    ,SUM(COALESCE(YE.WSUM_BAL,0)/100000000                                        AS WSUM_BAL         -- 余额加权值
    ,SUM(COALESCE(YE.WBAL_LM,0))/100000000                                        AS WBAL_LM          -- 余额加权值上期末
    ,SUM(COALESCE(YE.WBAL_YF,0))/100000000                                        AS WBAL_YF          -- 余额加权值年初
    ,SUM(COALESCE(YE.WBAL_LC,0))/100000000                                        AS WBAL_LC          -- 余额加权值去年同期
    FROM (SELECT * FROM EDW.DS_LOAB_SUM WHERE ENTERPRISE_SCALE IN('CS03','CS04') AND DATA_DATE='20180331') YE
    -- 与地区表最细级关联
    LEFT JOIN (SELECT * FROM DIMENSION.T_ORG_AREA_RELATION WHERE AREA_LEVEL='3') REAL ON YE.FIN_ORG_NO=REAL.ORG_ID AND '20180331' BETWEEN REAL.START_DATE AND REAL.END_DATE
    LEFT JOIN DIMENSION.T_AREA_CODE AREA ON REAL.AREA_CODE=AREA.AREA_CODE_4 AND '20180331' BETWEEN AREA.START_DATE AND AREA.END_DATE
    -- 关联机构表
    LEFT JOIN DIMENSION.T_ORG_REPORT ORG ON YE.ORG_TYPE=ORG.ORG_CODE
    GROUP BY  AREA.AREA_CODE_4
             ,YE.CCY
             ,ORG.ORG_CODE
             ,ORG.ORG_DSCR

    UNION ALL

    -- 合计
    SELECT
     AREA.AREA_CODE_4                                                             AS FIN_ORG_DIST
    ,YE.CCY                                                                       AS CCY
    ,ORG.ORG_CODE                                                                 AS ORG_TYP          -- 机构类型
    ,ORG.ORG_DSCR                                                                 AS ORG_DESC          -- 机构类型描述
    ,'Z'                                                                          AS ENTERPRISE_SCALE   -- 企业规模
    ,'合计'                                                                       AS SCALE_DESC         -- 企业规模描述
    ,SUM(COALESCE(YE.ACTUAL_BAL,0))/100000000                                     AS ACTUAL_BAL       -- 贷款余额
    ,SUM(COALESCE(YE.BAL_LM,0))/100000000                                         AS BAL_LM           -- 余额上期末
    ,SUM(COALESCE(YE.BAL_YF,0))/100000000                                         AS BAL_YF           -- 余额年初 0101
    ,SUM(COALESCE(YE.ACTUAL_BAL,0) - COALESCE(YE.BAL_LC,0))/100000000             AS BAL_GROW         -- 同比增长
    ,SUM(COALESCE(YE.WSUM_BAL,0)/100000000                                        AS WSUM_BAL         -- 余额加权值
    ,SUM(COALESCE(YE.WBAL_LM,0))/100000000                                        AS WBAL_LM          -- 余额加权值上期末
    ,SUM(COALESCE(YE.WBAL_YF,0))/100000000                                        AS WBAL_YF          -- 余额加权值年初
    ,SUM(COALESCE(YE.WBAL_LC,0))/100000000                                        AS WBAL_LC          -- 余额加权值去年同期
    FROM (SELECT * FROM EDW.DS_LOAB_SUM WHERE ENTERPRISE_SCALE IN('CS01','CS02','CS03','CS04') AND DATA_DATE='20180331') YE
    -- 与地区表最细级关联
    LEFT JOIN (SELECT * FROM DIMENSION.T_ORG_AREA_RELATION WHERE AREA_LEVEL='3') REAL ON YE.FIN_ORG_NO=REAL.ORG_ID AND '20180331' BETWEEN REAL.START_DATE AND REAL.END_DATE
    LEFT JOIN DIMENSION.T_AREA_CODE AREA ON REAL.AREA_CODE=AREA.AREA_CODE_4 AND '20180331' BETWEEN AREA.START_DATE AND AREA.END_DATE
    -- 关联机构表
    LEFT JOIN DIMENSION.T_ORG_REPORT ORG ON YE.ORG_TYPE=ORG.ORG_CODE
    GROUP BY  AREA.AREA_CODE_4
             ,YE.CCY
             ,ORG.ORG_CODE
             ,ORG.ORG_DSCR;